java String hashcode缓存机制
全部标签 在我的项目中,我们使用Lucene2.4.1进行全文搜索。这是一个J2EE项目,IndexSearcher创建一次。在后台,索引每两分钟刷新一次(当内容改变时)。用户可以通过页面上的搜索机制搜索索引。问题是,Lucene返回的结果似乎以某种方式被缓存了。这是我注意到的场景:我启动应用程序并搜索“关键字”-返回了6个结果,索引已刷新,使用Luke我看到,现在有8个结果可以查询“关键字”,我再次使用该应用程序进行搜索,再次返回6个结果。我分析了我们的配置,并没有在任何地方发现任何缓存。我调试了搜索,输出代码中没有缓存,searcher.search返回6个结果。Lucene是否以某种方式在
在tomcat上设置缓存的最佳方法是什么?还有缓存是如何工作的?它是基于url,基于目录还是什么?我需要特定于url的缓存,这样数据库就不会对相同的url进行相同的计算 最佳答案 最简单的方法是使用专用的网络缓存提供程序。Tomcat没有OOTB,但您可以使用Apachewithmod_cache(显然是mod_jk)。在此配置中,Apache倾向于充当缓存由Tomcat提供的动态内容的代理缓存;您必须确保Tomcat提供正确的header以确保Apache缓存响应。还有其他商业网络缓存解决方案,但它们通常用于高端用途。您还可以使用
我目前正在尝试使用hibernate附带的缓存提供程序让hibernate工作。net.sf.ehcache.hibernate.SingletonEhCacheProvider我在我的hibernate.cfg.xml文件中引用的ecache.xml中启用了默认缓存和类特定缓存。类/映射文件特定缓存被定义为处理多达20000个对象。但是,自从我在我用来测试它的映射文件之一上打开缓存映射后,我没有看到任何性能提升。我的测试如下。加载特定映射文件im测试的10000个对象(这应该会影响数据库并成为瓶颈)。接下来我去加载相同的10000个对象,因为此时我希望缓存被命中并看到显着的性能提升。
Strings1="String1";System.out.println(s1.hashCode());//returnanintegeri1Fieldfield=String.class.getDeclaredField("value");field.setAccessible(true);char[]value=(char[])field.get(s1);value[0]='J';value[1]='a';value[2]='v';value[3]='a';value[4]='1';System.out.println(s1.hashCode());//returnsameval
我有以下代码:publicclassCache{privatefinalMapmap=newConcurrentHashMap();publicObjectget(Objectkey){Objectvalue=map.get(key);if(value==null){value=newSomeObject();map.put(key,value);}returnvalue;}}我的问题是:map的put和get方法是线程安全的,但由于整个block未同步-多个线程可以添加相同的键两次吗? 最佳答案 put和get是线程安全的,因为从
我有一个应用程序,可以从数据库中获取数据(使用hibernate)。我想每天一次用数据库状态加载缓存(每个用户),然后改用缓存。我将Spring框架与Hibernate一起使用,我知道它们都有一些缓存的可能性。它们之间有什么区别?什么是更好的选择? 最佳答案 StartingwithHibernatecacheisamoreprudentdecisioninmyview,especiallybecausethetwodon'texcludeeachother.IntermsofperformanceSpringcachecanoff
似乎java正在对URL(和文件)进行某种缓存。例如我的类路径中的jar文件中有一个文件“resourcs.txt”。这个文件的内容是:“版本1”newjava.io.BufferedReader(newjava.io.InputStreamReader(newURL("jar","","file:test.jar!/resourcs.txt").openConnection().getInputStream())).readLine()返回“版本1”(如预期的那样)我将文件内容更改为“版本2”并再次调用此代码。我仍然得到“版本1”我怎样才能清除这个“缓存”。注意:我发现它只发生在Li
我在独立环境中使用Spring3.1。我正在使用@Cachable注释缓存我的条目。有时我需要遍历缓存列表以获取特定值(不是键)。所以我设法检索了缓存列表,但我如何迭代它的元素。privateClientDTOgetClientDTOByClientId(IntegerclientId){CacheclientCache=null;try{clientCache=ehCacheCacheManager.getCache("client");//needheretoiterateonclientCache.how?}catch(Exceptione){log.error("Couldnt
在我的笔记中发现了以下内容,但我无法理解:Primitivetypewrapperclassesimplementcachingforalimitednumberofvalues.Thisguaranteesthatalimitednumberofdeeplyequalwrapperobjectsarealsoshallowlyequal:Ifo1.equals(o2)theno1==o2.Forexample,newInteger(0)==newInteger(0).Ingeneralthisdoesnotalwayswork.Forexample,newInteger(666)==
我想要一个HashMap,每天午夜,缓存都会过期。请注意,它是J2EE解决方案,因此多个线程可以访问它。用Java实现它的最佳方法是什么? 最佳答案 虽然其他建议也可以用来计算过期时间,但请务必注意:hashmap的过期可以延迟完成即没有任何监控线程!实现过期的最简单方法如下:1)扩展HashMap,并创建一个本地nextMidtime(Long)变量,在构造函数中初始化为System.currentTime....。这将被设置为等于下一个午夜时间,以毫秒为单位...2)将以下代码段添加到“containsKey”和“get”方法(